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(57) Abstract 



The intelligent data storage manager functions to combine the non-homogeneous physical devices contained in a data storage subsystem 
to create a logical device with new and unique quality of service characteristics that satisfy the criteria for the policies appropriate for 
the present data object. In particular, if there is presently no logical device that is appropriate for use in storing the present data object, 
the intelligent data storage manager defines a new logical device using existing physical and/or logical device definitions as component 
building blocks to provide the appropriate characteristics to satisfy the policy requirements. The intelligent data storage manager uses 
weighted values that are assigned to each of the presently defined logical devices to produce a best fit solution to the requested policies in 
an n-dimensional best fit matching algorithm. The resulting logical device definition is then implemented by dynamically interconnecting 
the logical devices that were used as the components of the newly defined logical device to store the data object. 



3[XX:JD: <WO_0041510A2_I_> 



FOR THE PURPOSES OF INFORMATION ONLY 
Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCT. 



AL 


Albania 


ES 


Spain ' 


LS 


Lesotho 


SI 


Slovenia 


AM 


Armenia 


FI 


Finland 


LT 


Lithuania 


SK 


Slovakia 


AT 


Austria 


FR 


France 


LU 


Luxembourg 


SN 


Senegal 


AD 


Australia 


GA 


Gabon 


LV 


Latvia 


SZ 


Swaziland 


AZ 


Azerbaijan 


GB 


United Kingdom 


MC 


Monaco 


TD 


Chad 


BA 


Bosnia and Herzegovina 


GE 


Georgia 


MD 


Republic of Moldova 


TG 


Togo 


BB 


Barbados 


GH 


Ghana 


MG 


Madagascar 


TJ 


Tajikistan 


BE 


Belgium 


GN 


Guinea 


MK 


The former Yugoslav 


TM 


Turkmenistan 


BF 


Burkina Faso 


GR 


Greece 




Republic of Macedcmia 


TR 


Turkey 


BG 


Bulgaria 


HU 


Hungary 


ML 


Mali 


TT 


Trinidad and Tobago 


BJ 


Benin 


IE 


Ireland 


MN 


Mongolia 


UA 


Ukraine 


BR 


Brazil 


IL 


Israel 


MR 


Mauritania 


UG 


Uganda 


BY 


Belarus 


IS 


Iceland 


MW 


Malawi 


US 


United States of America 


CA 


Canada 


IT 


Italy 


MX 


Mexico 


uz 


Uzbekistan 


CF 


Central African Republic 


JP 


Japan 


NE 


Niger 


VN 


Viet Nam 


CC 


Congo 


KE 


Kenya 


NL 


Netherlands 


YU 


Yugoslavia 


CH 


Switzerland 


KG 


Kyrgyzstan 


NO 


Norway 


ZW 


2mbabwe 


CI 


Cdte d'lvoire 


KP 


Democratic People's 


NZ 


New Zealand 






CM 


Cameroon 




Republic of Korea 


PL 


Poland 






CN 


China 


KR 


Republic of Korea 


PT 


Portugal 






cu 


Cuba 


KZ 


Kazakstan 


RO 


Romania 






cz 


Czech Republic 


LC 


Saint Lucia 


RU 


Russian Federation 






DE 


Germany 


U 


Liechtenstein 


SD 


Sudan 






DK 


Denmark 


LK 


Sri Lanka 


SE 


Sweden 






EE 


Estonia 


LR 


Liberia 


SG 


Singapore 







SDCDCID: <WO_0041S10A2J_> 



wo 00/41510 PCT/USOO/01052 

INTELLIGENT DATA STORAGE MANAGER 
Field of the Invention 

This invention relates to data storage subsystems and. in particular, to a 
dynamically mapped virtual data storage subsystem which includes a data storage 
manager that functions to combine the non-homogeneous physical devices 
contained in the data storage subsystem to create a logical device with new and 
5 unique quality of service characteristics that satisfy the criteria for the policies 
appropriate for the present data object. 

Problem 

It is a problem in the field of data storage subsystems to store the ever 
increasing volume of application data in an efficient manner, especially in view of 

1 0 the rapid changes in data storage characteristics of the data storage elements that 
are used to implement the data storage subsystem and the increasingly specific 
need of the applications that generate the data. 

Data storage subsystems traditionally comprised homogeneous collections 
of data storage elements on which the application data was stored for a plurality 

15 of host processors. As the data storage technology changed and a multitude of 
different types of data storage elements became available, the data storage 
subsystem changed to comprise subsets of homogeneous collections of data 
storage elements, so that the application data could be stored on the most 
appropriate one of the plurality of subsets of data storage elements. Data storage 

20 management systems were developed to route the application data to a selected 
subset of data storage elements and a significant amount of processing was 
devoted to ascertaining the proper data storage destination for a particular data set 
in terms of the data storage characteristics of the selected subset of data storage 
elements. Some systems also migrate data through a hierarchy of data storage 

25 elements to account for the timewise variation in the data storage needs of the data 
sets. 

In these data storage subsystems, the quality of service characteristics are 
determined by the unmodified physical attributes of the data storage elements that 
are used to populate the data storage subsystem. One exception to this rule is 
30 disclosed in U.S. Patent No. 5,430,855 titled *'Disk Drive Array Memory System 
Using Nonuniform Disk Drives," which discloses a data storage subsystem that 
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uses an array of data storage elements that vary in their data storage 
characteristics and/or data storage capacity. The data storage manager in this 
data storage subsystem automatically compensates for any nonuniformity among 
the disk drives by selecting a set of physical characteristics that define a common 
5 data storage element format. However, the data storage utilization of the 
redundancy groups formed by the data storage manager is less than optimal, since 
the least common denominator data storage characteristics of the set of disk drives 
is used as the common disk format. Thus, disk drive whose data storage capacity 
far exceeds the smallest capacity disk drive in the redundancy group suffers from 

10 iossof utilization of its excess data storage capacity. Therefore, most data storage 
subsystems do not utilize this concept and simply configure multiple redundancy 
groups, with each redundancy group comprising a homogeneous set of disk drives. 
A problem with such an approach is that the data storage capacity of the data 
storage subsystem must increase by the addition of an entire redundancy group. 

1 5 Furthermore, the replacement of a failed disk drive requires the use of a disk drive 
that matches the characteristics of the remaining disk drives in the redundancy 
group, unless loss of the excess data storage capacity of the newly added disk 
drive were incurred, as noted above. 

Thus, it is a prevalent problem in data storage subsystems that the 

20 introduction of new technology is costly and typically must occur in fairly large 
increments, occasioned by the need for the data storage subsystem to be 
comprised of homogeneous subset of data storage devices, even in a virtual data 
storage subsystem. Therefore, data administrators find it difficult to cost effectively 
manage the increasing volume of data that is being generated in order to meet the 

25 needs of the end users' business. In addition, the rate of technological innovation 
is accelerating, especially in the area of increases in data storage capacity and the 
task of incrementally integrating these new solutions into existing data storage 
subsystems is difficult to achieve. 

Solution 

30 The above described problems are solved and a technical advance 

achieved by the present intelligent data storage manager that functions to combine 
the non-homogeneous physical devices contained in a data storage subsystem to 
create a logical device with new and unique quality of service characteristics that 

2 
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satisfy the criteria for the policies appropriate for the present data object. In 
particular, if there is presently no logical device that is appropriate for use in storing 
the present data object, the intelligent data storage manager defines a new logical 
device using existing physical and/or logical device definitions as component 
5 building blocks to provide the appropriate characteristics to satisfy the policy 
requirements. The intelligent data storage manager uses weighted values that are 
assigned to each of the presently defined logical devices to produce a best fit 
solution to the requested policies in an n-dimensional best fit matching algorithm. 
The resulting logical device definition is then implemented by dynamically 

1 0 interconnecting the logical devices that were used as the components of the newly 
defined logical device to store the data object 

Brief Description of the Drawing 
Figure 1 illustrates in block diagram form the overall architecture of a data 
storage subsystem in which the present intelligent data storage manager is 

15 implemented; 

Figure 2 Illustrates a three-dimensional chart of the operating environment 
of the present intelligent data storage manager; 

Figure 3 illustrates one example of a virtual device that can be configured 
by the present intelligent data storage manager; and 
20 Figure 4 illustrates a three-dimensional chart of a user policy that must 

resolve priorities between two attributes: Cost per MB. and Time to First Byte. 

Detailed Description 
Figure 1 illustrates in block diagram form the overall architecture of a data 
storage subsystem 100 in which the present intelligent data storage manager 110 
25 is implemented. The data storage subsystem is connected to a plurality of host 
processors 1 11-114 by means of a number of standard data channels 121-124. 
The data channels 121-124 are terminated in a host interface 101 which provides 
a layer of name servers 131-134 to present virtual implementations of existing 
defined physical device interfaces to the host processors 111-114. As far as the 
30 host processors 111-114 are concerned, the name servers 131-134 implement a 
real physical device. The name servers 131-134 convert the user data received 
from the host processor 111-114 into a user data object which can be either 
converted into a canonical format or left in binary format. The object handle server 
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maps the object handle to logical device addresses and allows multiple instances 
of a data object. The object handle server 102 maps the user data object into a 
data space for storage. The mapping is determined by the policies programmed 
into the policy manager 105 of the data storage subsystem 100 and subject to 
5 security layer 1 03. The persistent storage for the object space is determined by the 
logical device manager 1 04 which allocates or creates a logical device based upon 
policiesfor storing the user data object. A logical device is a composite device and 
can consist of a real physical device such as a tape 1 51 . a disk 1 52. optical disk 
153, another logical device, such as Logical Device 1 which comprises a RAID 5 
1 0 disk array 1 54, Logical Device N which comprises middleware software 1 55 that 
accesses another logical device, such as access of a logical device over a network 
connection, or combinations of the above. The logical device definition abstracts 
the nature of the real device associated with the persistent storage. The changes 
implemented in the technology of the persistent storage are thereby rendered 
15 transparent to the host application. 

If there is presently no logical device that satisfies the criteria for the policies 
appropriate for a user data object, the logical device manager 104 creates a new 
logical device definition with the appropriate data storage characteristics to satisfy 
the policy requirements using existing physical and/or logical device definitions as 
20 component building blocks. The logical device manager 1 04 uses weighted values 
that are assigned to each of the presently defined logical devices to produce a best 
fit solution to the requested policies in an n-dimensional best fit matching algorithm. 
Thus, the intelligent data storage manager 1 1 0 maps the virtual device to the user 
data object rather than mapping a data object to a predefined data storage device. 
25 The various data storage attributes that are used by the intelligent data storage 
manager 110 to evaluate the appropriateness of a particular virtual device include, 
but are not limited to: speed of access to first byte, level of reliability, cost of 
storage, probability of recall, and expected data transfer rate. The logical device 
manager 104 stores the mapping data which comprises a real time definition of the 
30 available storage space in the data storage subsystem 100. Once one of the 
cun-ent logical device definitions meet the criteria required by a data object, the 
logical device manager 104 either allocates space on an existing instance of a 
logical device of that type or creates a new instance of that type of logical device. 
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Policy Attributes 

The policy attributes and the potential algorithms that are used to map user 
requirements to storage devices are managed by the intelligent storage manager 
110. A typical general set of attributes for storage devices is shown in Table 1 : 
5 Table 1 : Policy Attributes 



Name of Attribute 


Range of Values (Dimension) 


Cost per MB (Ig) 


$0.0001 to $1000.00 


Time to first byte (Ig) 


Ns to days 


Random read 


0.0001 to 1000 MB/sec 


Random write 


0.0001 to 1000 MB/sec 


Sequential read 


0.0001 to 1000 MB/sec 


Sequential write 


0,0001 to 1000 MB/sec 


Sequential (tape) or random 
(disk) storage or recall 


0 to 10 (where: 0= sequential, 10= 
random) 


Size (Ig) 


Bytes to petabytes 


Probability of recall 


0 to 10 (where: 0= lowest, 10= highest) 


Virtual or real Device 


yes/no 


Level of reliability 


0 to 10 (where: 0= minimum. 10= 100%) 


Others to be defined... 





20 

Each of these attributes has a range or dimension of "values". Each dimension 
needs to be relatively uniform in its number scheme. For example, each dimension 
could have a numeric value for 0.0 to 10.0. Some dimensions need to be 
logarithmic (Ig) because of the inherent nature of the dimension. For example, 

25 Cost per MB can be defined as a logarithmic dimension that runs from the $0,001 
for tape storage to $1 Os for RAM. So one approach is to do a distance calculation 
of the difference between the customer's policy requirements and each storage 
device's policy attributes. In addition, levels of priority among attributes can be 
specified since certain dimensions may be more important than others (reliability, 

30 for example). When the intelligent storage manager 110 must resolve between 
conflicting priority levels, the logical storage manager 104 tries to find ways to 
combine single devices into an optimal, logical device using logical combining 

5 
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operators. 

Operation of the Intelligent Data Storage Manaoer 
The present intelligent data storage manager 11 0 is responsive to one of the 
host processors 1 1 1 initiating a data write operation by transmitting a predefined 
5 set of commands over a selected one of the communication links to the data 
storage subsystem 100. These commands include a definition of the desired 
device on which the present data object is to be stored, typically in terms of a set 
of data storage characteristics. Figure 2 illustrates a three-dimensional (of the 
above-noted multiple dimensions) chart of the operating environment of the present 
10 intelligent data storage manager 110 and the location of the host specified data 
storage device with respect to this environment. In particular, as mapped in a 
Cartesian coordinate system, the cost, data transfer rate, and data access time 
comprise the three axes used to measure the performance characteristics of the 
various physical 151-153 and virtual154-155 devices of the data storage 

1 5 subsystem 1 00. As shown in Figure 3, the standard tape 151, disk 1 52, and optical 
153 devices each have a set of defined characteristics that can be mapped to the 
three-dimensional space of Figure 2. The user has requested that their data be 
stored on a device, whose data storage characteristics do not match the data 
storage characteristics of any of the devices presently defined in the data storage 

20 subsystem 100. The desired data storage characteristics are shown mapped as 
a locus in the three-dimensional space in Figure 2. The intelligent data storage 
manager 110 must therefore map the existing set of physical devices that are 
contained in the data storage subsystem 100 to satisfy the desired set of data 
storage characteristics defined by the user. This problem comprises a three- 

25 dimensional best fit mapping process wherein the set of available physical and 
virtual devices are mapped to match or at least approximate the desired set of data 
storage characteristics. This is accomplished by creating a composite virtual 
device that implements the defined desired data storage characteristics. For 
example, assume that the user has requested a data storage device that has a 

30 20MB/sec read performance and the data storage subsystem 1 00 is equipped with 
5MB/sec tape drives as one of the types of physical devices. The intelligent data 
storage manager 110 can create a 20MB/sec data storage device by configuring 
a Redundant Array of Inexpensive Tape drives (RAIT) to connect a plurality of the 
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existing tape drives 1 51 in parallel to thereby achieve the desired data throughput. 
Examples of Operation of the Intelligent Data Storage Manager 
There are many instances of data file storage where the needs of the 
application and/or user do not correspond to the reality of the data storage 

5 characteristics of the various data storage elements 151-153 and virtual data 
storage elements 154-155 that are available in the data storage subsystem 100. 
For example^ the application "video on demand" may require a high reliability data 
storage element and fast access to the initial portion of the file, yet not require fast 
access for the entirety of the file since the data is typically read out at a fairly slow 

10 data access rate. However, the required data transfer bandwidth may be large, 
since the amount of data to be processed is significant and having a slow speed 
access device as well as a narrow bandwidth would result in unacceptable 
performance. Furthermore, the cost of data storage is a concern due to the volume 
of data. The intelligent data storage manager 110 must therefore factor all of these 

15 data storage characteristics to determine a best fit data storage device or devices 
to serve these needs. In this example, the defined data storage characteristics 
may be partially satisfied by a Redundant Array of Inexpensive Tapes since the 
reliability of this data storage device is high as is the data bandwidth, yet the cost 
of implementation is relatively low. especially if the configuration is a RAIT-5 and 

20 the data access speed is moderate. In making a determination of the appropriate 
data storage device, the intelligent data storage manager 110 must review the 
criticality of the various data storage characteristics and the amount of variability 
acceptable for that data storage characteristic. 

Definina Attribute Values 

25 All devices support some form of quality of service, which can be described 

as attributes with certain fixed values. For example, they cost $xxx per megabyte 
of data or have nnn access speed. The intelligent storage manager 110 provides 
an algorithmic way to use these attributes to determine the perfect device, as 
specified by user policy. In some cases, the perfect device is a logical device that 

30 is constmcted when the intelligent storage manager 110 rank orders the distance 
between 1 ) how the user would like to have data stored and 2) the storage devices 
that are available. This logical device can span both disk and tape subsystems 
and, therefore, blurs the distinction between disk and tape. 
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The diagram of Figure 4 shows an example of a user policy that must 
resolve priorities bebA^een two attributes: Cost per MB, and Time to First Byte. To 
resolve this, the intelligent storage manager 1 1 0 could create a logical device that 
is the mixture of disk and tape that best conforms to the specific policies the user 
has requested. In this example, some data could be stored on disk for quick 
access and some data could be stored on tape for lower cost of storage. Or the 
intelligent storage manager 110 could create a policy that migrates a small file 
between disk and tape over time: after a week the file would be transferred to tape 
to lower storage cost. 

Table 2 provides a more complex comparison of device attributes versus 
attributes defined through user policy. In this example, the set of attributes of the 
following storage subsystems: single disk, RAID, single tape drive, and RAIT are 
listed. The intelligent storage manager 1 1 0 determines an optimal storage solution 
by doing a distance calculation between 1 ) the set of attributes for each device and 
2) the set of attributes for a file (defined through user policy). 

For example, the calculation below denotes the vector for point P by [x1(P), 
x2(P), x3(P)]. Then the distance between points 1 and 2 is 

V [(x1-x2)2+(y1.y2)2+(z1-22)2] 

Where: x1 is the attribute value defined by user policy. 

x2 is the attribute value defined for the device. 

This example is for three dimensions. To extend it to more dimensions, take 
the difference between corresponding components of the two vectors, square this 
difference, add this square to all the other squares, and take the square root of the 
sum of the squares. Of course, you don't need to do the square root if youVe 
simply looking for the point closest to a give point. 
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Device 


Cost/MB 


Time to 

first 

byte 


MB/sec 
read 


MB/sec 
write 


Sequential 
or Random 


Reliability 


Disk 


0.15 


12ms 


3MB/sec 


3MB/sec 


5 


1 


RAID 


10.00 


6rns 


80MB/sec 


20MB/se 
c 


3 


3 


Tape 


.001 


30sec 


5MB/sec 


5MB/sec 


0 


2 


RAIT 


.005 


40sec 


20MB/sec 


20MB/se 
c 


0 


4 


User-defined policy (per attribute) 


File 


.01 


1 sec or 
less 


.1 MB/sec 
or less 


.1 

MB/sec 
or less 


0 


3 



In the present example, the realized data storage device can be a composite 
device or a collection of composite devices. For example, the video on demand file 
data storage requirements can be met by the virtual device illustrated in Figure 3. 

15 The virtual device 300 can comprise several elements 301, 302, each of which 
itself comprises a collection of physical and/or virtual devices. The virtual device 
300 comprises a first device 301 which comprises a set of parallel connected disk 
drives 310-314 that provides a portion of the data storage capability of the virtual 
device 300. These parallel connected disk drives 310-314 provide a fast access 

20 time for the application to retrieve the first segment of the video on demand data 
to thereby provide the user with a fast response time to the file request. The bulk 
of the video on demand data file is stored on a second element 302 that comprises 
a Redundant Array of Inexpensive Tapes device that implements a RAIT-5 storage 
configuration. The relative data storage capacity of the two data storage elements 

25 301 , 302 is determined by the amount of data that must be provided to the user on 
a priority basis and the length of time before the remainder of the file can be staged 

9 
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for provision to the user. 

Time Analysts 

The data storage manager 1 1 0 implements devices that support some form 
of quality of service. These attributes have some type of fixed value: they cost so 
5 much- they have XX access speed. The data storage manager 11 0 can also rank 
order the distances between how the user wishes to have a data file stored 
compared to the storage devices that are in the data storage subsystem 100. From 
this the data storage manager 1 1 0 can also come up with some alternative storage 
methods- for example, the data storage manager 1 1 0 can do a mixture of disk and 
1 0 tape to achieve the qualities that the user is looking for. The data storage manager 
1 1 0 can put some of the data file on disk for quick access and some of it on tape 
for cheap storage as noted above. Another alternative factor is if there is a file that 
the user wants stored at a certain $$ per megabyte, it can be migrated from disk 
to tape over a certain period of weeks and the average cost of storage complies 

1 5 with the user policy definition. So, the data storage manager 1 1 0 must evaluate 
quickly what devices are available and the data storage manager 110 compares 
how the user wants to store the data file. If the data storage manager 1 1 0 doesn't 
have a perfect match, the mixtures of devices are rank ordered and investigated 
to try and achieve the policy that is defined by the user. 

20 Summarv 

The intelligent data storage manager functions to combine the non- 
homogeneous physical devices contained in a data storage subsystem to create 
a logical device with new and unique quality of service characteristics that satisfy 
the criteria for the policies appropriate for the present data object. The intelligent 

25 data storage manager uses weighted values that are assigned to each of the 
presently defined logical devices to produce a best fit solution to the requested 
policies in an n-dimensional best fit matching algorithm. The resulting logical 
device definition is then implemented by dynamically interconnecting the logical 
devices that were used as the components of the newly defined logical device to 

30 store the data object. 



10 
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1 . A data storage manager operational in a data storage subsystem that 
uses a plurality of data storage elements to store data thereon for a plurality of host 
processors that are connected to said data storage subsystem, comprising: 

means for storing a set of logical data storage device definitions that are 
5 created from said plurality of data storage elements; 

means for identifying a set of data storage characteristics appropriate for a 
present data object; 

means for comparing said identified set of data storage characteristics with 
said stored set of logical data storage device definitions; 
10 means, responsive to a failure to match said identified set of data storage 

characteristics with a single one of said stored set of logical data storage device 
definitions, for creating a new logical device definition using a plurality of said 
stored set of logical data storage device definitions; and 

means for storing said present data object on interconnected ones of said 
plurality of data storage elements that correspond to said new logical device 
definition. 

2. The data storage manager of claim 1 wherein said means for creating 
comprises: 

means for assigning weighted values to each of the presently defined logical 
devices to produce a best fit solution to the requested policies in an n-dimensional 
5 best fit matching algorithm. 

3. The data storage manager of claim 1 wherein said means for creating 
comprises: 

means for implementing the resulting logical device definition by dynamically 
interconnecting the logical devices that were used as the components of the newly 
5 defined logical device to store the data object. 

4. The data storage manager of claim 1 wherein said means for storing 
comprises: 

means for allocating space on an existing instance of said interconnected 

11 
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ones of said plurality of data storage elements that con-espond to said new logical 
5 device definition. 



5. The data storage manager of claim 1 wherein said means for storing 
comprises: 

means for creating a new instance of said interconnected ones of said 
plurality of data storage elements that correspond to said new logical device 
5 definition. 

6. The data storage manager of claim 1 wherein said means for storing 
comprises: 

means for storing data indicative of a plurality of data storage attributes from 
the class of data storage attributes comprising: speed of access to first byte, level 
5 of reliability, cost of storage, probability of recall, and expected data transfer rate. 

7. A method of operating a data storage manager operational in a data 
storage subsystem that uses a plurality of data storage elements to store data 
thereon for a plurality of host processors that are connected to said data storage 
subsystem, comprising the steps of: 

5 storing a set of logical data storage device definitions that are created from 

said plurality of data storage elements; 

identifying a set of data storage characteristics appropriate for a present 
data object; 

comparing said identified set of data storage characteristics with said stored 
1 0 set of logical data storage device definitions; 

creating, in response to a failure to match said identified set of data storage 
characteristics with a single one of said stored set of logical data storage device 
definitions, a new logical device definition using a plurality of said stored set of 
logical data storage device definitions; and 
1 5 storing said present data object on interconnected ones of said plurality of 

data storage elements that correspond to said new logical device definition. 
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8. The method of operating a data storage manager of claim 7 wherein 
said step of creating comprises: 

assigning weighted values to each of the presently defined logical devices 
to produce a best fit solution to the requested policies in an n-dimensional best fit 
5 matching algorithm. 

9. The method of operating a data storage manager of claim 7 wherein 
said step of creating further comprises: 

implementing the resulting logical device definition by dynamically 
interconnecting the logical devices that were used as the components of the newly 
5 defined logical device to store the data object. 

1 0. The method of operating a data storage manager of claim 7 wherein 
said step of storing comprises: 

allocating space on an existing instance of said interconnected ones of said 
plurality of data storage elements that correspond to said new logical device 
5 definition. 

1 1 . The method of operating a data storage manager of claim 7 wherein 
said step of storing further comprises: 

creating a new instance of said interconnected ones of said plurality of data 
storage elements that correspond to said new logical device definition. 

1 2. The method of operating a data storage manager of claim 7 wherein 
said step of storing comprises: 

storing data indicative of a plurality of data storage attributes from the class 
of data storage attributes comprising: speed of access to first byte, level of 
5 reliability, cost of storage, probability of recall, and expected data transfer rate. 
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